{% extends 'layout/basic.html' %}
{% load static %}

{% block title %}用户短信登录{% endblock %}

{% block css %}
    <link rel="stylesheet" href="{% static 'css/account.css' %}">
    <style>
        .error-msg{
            color: red;
            position: absolute;
            font-size: 13px;
        }
    </style>
{% endblock %}

{% block content %}
    <div class="account">
        <div class="title">用户短信登录</div>
        <form id="logForm" method="POST" novalidate>
            {% csrf_token %}
            {% for field in form %}
                {% if field.name == 'code' %}
                    <div class="form-group">
                        <label for="{{ field.id_for_label }}">{{ field.label }}</label>
                        <div class="row">
                            <div class="col-xs-7">
                                {{ field }}
                                <span class="error-msg"></span>
                            </div>
                            <div class="col-xs-5">
                                <input id="btnSms" type="button" class="btn btn-default" value="点击获取验证码">
                            </div>
                        </div>
                    </div>
                {% else %}
                    <div class="form-group">
                        <label for="{{ field.id_for_label }}">{{ field.label }}</label>
                        {{ field }}
                        <span class="error-msg"></span>
                    </div>
                {% endif %}
            {% endfor %}
            <div>
                <div style="float: right">
                    <a href="{% url 'login' %}"/>邮箱或手机号登录</a>
                </div>
            </div>

            <div class="row">
                <div class="col-xs-3">
                    <input id="btnSubmit" type="button" class="btn btn-primary" value="登   录"/>
                </div>
            </div>


        </form>
    </div>
{% endblock %}

{% block js %}
    <script>
    $(function () {
        bindClickBtnSms();
        bindClickSubmit();
    });
    function bindClickSubmit() {
        $('#btnSubmit').click(function () {
            $('.error-msg').empty()
            $.ajax({
                url:'{% url 'login_sms' %}',
                type: 'POST',
                data:$('#logForm').serialize(), // 所有字段数据 + csrf_token
                dataType: "JSON",
                success:function (res) {
                    if(res.status){
                        location.href = res.data;
                    }else {
                        $.each(res.error, function (key,value) {
                            $("#id_" + key).next().text(value[0]);
                        })
                    }
                }
            })
        })
    }

    function bindClickBtnSms() {
        $('#btnSms').click(function () {
            // 每次点击都先清除遗留的错误信息
            $('.error-msg').empty()
            // 获取用户输入的手机号
            // 找到输入框的ID，根据ID获取值，为id_字段名
            var mobilePhone = $('#id_mobile_phone').val()

            // 发送ajax请求，把手机号发送过去
            $.ajax({
                url:"{% url 'send_sms' %}", //等价于 /send/sms/
                type:"GET",
                data:{ mobile_phone:mobilePhone,tpl:"login"},
                dataType:"JSON",    // 将服务端返回的数据反序列化为字典
                success: function (res) {
                    // ajax请求发送成功之后，自动执行的函数；res就是后端返回的数据
                    {#console.log(res)#}
                    if (res.status){
                        sendSmsRemind();
                    }else {
                        // 错误信息
                        // console.log(res); //{status:False, erro:{ mobile_phone: ["错误信息",],code: ["错误信息",]}}
                        $.each(res.error, function (key,value) {
                            $("#id_" + key).next().text(value[0]);
                        })
                    }
                }
            })
        })
    }

    function sendSmsRemind() {
        var $smsBtn = $('#btnSms')
        $smsBtn.prop('disabled',true); // 禁用发送验证码按钮
        var time = 60;
        var remind = setInterval(function () {
            $smsBtn.val(time+'秒后重新发送');
            time = time - 1;
            if (time<1){
                clearInterval(remind)
                $smsBtn.val('点击获取验证码').prop('disabled',false);
            }
        },1000)
    }


    </script>
{% endblock %}